vue项目不被百度收录

您所在的位置:网站首页 无标题页面 百度能收录吗 vue项目不被百度收录

vue项目不被百度收录

2024-04-03 21:59| 来源: 网络整理| 查看: 265

项目上线了,突然收到说项目不利于百度蜘蛛爬取网页??半路接手项目当时就知道会有这么一个问题,预料之中、预料之中...

采用前后端分离模式,spa单页面应用,打包之后只有一个index.html页面,而且里面什么都没有不利于百度爬取。

那么解决呗。方案有如下:

1、vue.js官网提供SSR服务端渲染(详情见官网),由于项目已经上线使用,如果采用这种模式基本得重构项目,成本高等其他因素。

2、prerender-spa-plugin预渲染,相对较简单安装prerender-spa-plugin直接使用,打包后会生成对应自己的静态文件,可以提高网页访问速度。可以设置mate添加关键字、描述、标题,项目较大的话则不太友好。

3、使用Phantomjs针对爬虫做处理,Phantomjs是一个基于webkit内核的无头浏览器,没有UI界面,它就是一个浏览器,只是其内的点击、翻页等人为相关操作需要程序设计实现。

这种解决方案其实是一种旁路机制,原理就是通过Nginx配置, 判断访问的来源UA是否是爬虫访问,如果是则将搜索引擎的爬虫请求转发到一个node server,再通过PhantomJS来解析完整的HTML,返回给爬虫。

线上要安装 node 、 pm2 、 phantomjs ,nginx相关配置。

部署需要node服务器支持;

爬虫访问比网页访问要慢一些,因为定时要定时资源加载完成才返回给爬虫;

如果被恶意模拟百度爬虫大量循环爬取,会造成服务器负载方面问题,解决方法是判断访问的IP,是否是百度官方爬虫的IP。

综合项目情况采用了prerender-spa-plugin预渲染,改动较小安装直接使用(这里只做了首页的优化)

安装prerender-spa-plugin:

npm install prerender-spa-plugin --save

安装这个网络要稍微稳定好点,可能会安装失败,别灰心继续加油!

npm cache clean --force // 如果失败清除缓存 再来

装好之后在webpack.prod.conf.js或者vue.config.js中增加配置:

const PrerenderSPAPlugin = require('prerender-spa-plugin'); const Renderer = PrerenderSPAPlugin.PuppeteerRenderer; configureWebpack: config => { if (process.env.NODE_ENV !== 'production') return; return { plugins: [ new PrerenderSPAPlugin({ staticDir: path.join(__dirname, './dist'), routes: ['/','/home'], // 需要预渲染的路由 renderer: new Renderer({ inject: { foo: "bar" }, headless: false, renderAfterDocumentEvent: 'render-event' }) }) ] } }

staticDir里面的dist是输出文件夹名字

routes配置的是你想实现预渲染的路由(可以多个 根据需要)

renderer预渲染提供了三种时机实现,renderAfterDocumentEvent、renderAfterTime、renderAfterElementExists

然后再main.js中修改

new Vue({ router, store, render: function (h) { return h(App) }, mounted () {//新增 document.dispatchEvent(new Event('render-event')) } }).$mount('#app');

最后打包出来的文件会根据所配置的路由生成对应的独立文件夹。

注意路由需要采用mode: 'history'模式,不然不能生效。

总之项目开发初期就应该考虑到各种因素而来确定使用什么技术,是否有解决方案。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3